package org.dromara.business.domain;

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
import org.dromara.common.tenant.core.TenantEntity;

import java.io.Serial;
import java.math.BigDecimal;
import java.util.Date;

/**
 * 用户信息对象 sys_user
 *
 * @author zlj
 * @date 2024-11-19
 */
@Data
@EqualsAndHashCode(callSuper = true)
@NoArgsConstructor
@TableName("sys_user")
public class User extends TenantEntity {

    @Serial
    private static final long serialVersionUID = 1L;

    /**
     * 用户ID
     */
    @TableId(value = "user_id")
    private Long userId;

    /**
     * 部门ID
     */
    private Long deptId;

    /**
     * 用户账号
     */
    private String userName;

    /**
     * 用户昵称
     */
    private String nickName;

    /**
     * 用户类型（sys_user系统用户）
     */
    private String userType;

    /**
     * 用户邮箱
     */
    private String email;

    /**
     * 手机号码
     */
    private String phonenumber;

    /**
     * openid
     */
    private String openid;

    /**
     * unionid
     */
    private String unionid;

    /**
     * 用户性别（0男 1女 2未知）
     */
    private String sex;

    /**
     * 头像地址
     */
    private Long avatar;

    /**
     * 密码
     */
    private String password;

    /**
     * 积分
     */
    private BigDecimal amount;

    /**
     * 总花费金额 用于用户vip等级评定
     */
    private Integer allAmount;

    /**
     * 帐号状态（0正常 1停用）
     */
    private String status;

    /**
     * 删除标志（0代表存在 2代表删除）
     */
    @TableLogic
    private String delFlag;

    /**
     * 最后登录IP
     */
    private String loginIp;

    /**
     * 最后登录时间
     */
    private Date loginDate;

    /**
     * 备注
     */
    private String remark;

    /**
     * 二维码
     */
    private Long qrCode;

    /**
     * 上级
     */
    private Long superiorId;

    /**
     * 微信头像地址
     */
    private String wxAvatar;

    // 1未审核 2待审核 3审核通过 4审核未通过
    private String ifCardReview;

    //审核理由
    private String reasonsReview;

    private Long idCardId;

    private Long idCardNegativeId;
    // 手持身份证正面
    private Long idCardIdSczm;

    // 身份证号码
    private String sfzHm;
    // 身份证姓名
    private String sfzXm;
    private String vip;
    private Date gqTime;
    private Integer hyNumber;

    private String type;
    /**
     * 我的帮扶
     */
    private String assistedUserId;


    /**
     * 我的图片
     */
    private String picture;


    /**
     * 帮扶我的
     */
    private String helperuUserId;

    /**
     * 抽奖次数
     */
//    private Integer numberDraws;
    @TableField(exist = false)
    private boolean ifhy = false;


    /**
     * 姓名
     */
    private String name;

}
